home *** CD-ROM | disk | FTP | other *** search
/ EnigmA Amiga Run 1995 October / EnigmA AMIGA RUN 01 (1995)(G.R. Edizioni)(IT)[!][issue 1995-10][Aminet 7].iso / Aminet / dev / gcc / ixemul_src.lha / ixemul-41.0 / library / ftruncate.c < prev    next >
C/C++ Source or Header  |  1995-05-28  |  2KB  |  86 lines

  1. /*
  2.  *  This file is part of ixemul.library for the Amiga.
  3.  *  Copyright (C) 1991, 1992  Markus M. Wild
  4.  *
  5.  *  This library is free software; you can redistribute it and/or
  6.  *  modify it under the terms of the GNU Library General Public
  7.  *  License as published by the Free Software Foundation; either
  8.  *  version 2 of the License, or (at your option) any later version.
  9.  *
  10.  *  This library is distributed in the hope that it will be useful,
  11.  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
  12.  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  13.  *  Library General Public License for more details.
  14.  *
  15.  *  You should have received a copy of the GNU Library General Public
  16.  *  License along with this library; if not, write to the Free
  17.  *  Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  18.  *
  19.  *  ftruncate.c,v 1.1.1.1 1994/04/04 04:30:18 amiga Exp
  20.  *
  21.  *  ftruncate.c,v
  22.  * Revision 1.1.1.1  1994/04/04  04:30:18  amiga
  23.  * Initial CVS check in.
  24.  *
  25.  *  Revision 1.1  1992/05/14  19:55:40  mwild
  26.  *  Initial revision
  27.  *
  28.  */
  29.  
  30. #define KERNEL
  31. #include "ixemul.h"
  32. #include "kprintf.h"
  33.  
  34. #ifndef ACTION_SET_FILE_SIZE
  35. #define ACTION_SET_FILE_SIZE 1022
  36. #endif
  37.  
  38. int
  39. ftruncate (int fd, long len)
  40. {
  41.   struct file *f = u.u_ofile[fd];
  42.   int err, res;
  43.   int omask;
  44.  
  45.   errno = EBADF;
  46.   KPRINTF (("&errno = %lx, errno = %ld\n", &errno, errno));
  47.  
  48.   /* if this is an open fd */
  49.   if (fd >= 0 && fd < NOFILE && f)
  50.     {
  51.       if (f->f_type == DTYPE_FILE)
  52.     {
  53.           if (HANDLER_NIL (f))
  54.         {
  55.           errno = EINVAL;
  56.           KPRINTF (("&errno = %lx, errno = %ld\n", &errno, errno));
  57.           return -1;
  58.         }
  59.  
  60.       err = 0;
  61.       omask = syscall (SYS_sigsetmask, ~0);
  62.       __get_file (f);
  63.       __wait_packet(&f->f_sp);
  64.       SendPacket3(f, __rwport,ACTION_SET_FILE_SIZE,
  65.                       f->f_fh->fh_Arg1,
  66.                       len, OFFSET_BEGINNING);
  67.       __wait_packet(&f->f_sp);
  68.       res = LastResult(f) != -1 ? 0 : -1;
  69.       if (res == -1) err = __ioerr_to_errno(LastError(f));
  70.       LastResult(f) = 0;
  71.       __release_file (f);
  72.       syscall (SYS_sigsetmask, omask);
  73.       errno = err;
  74.       KPRINTF (("&errno = %lx, errno = %ld\n", &errno, errno));
  75.       return res;
  76.     }
  77.       else
  78.     {
  79.       errno = ESPIPE;
  80.       KPRINTF (("&errno = %lx, errno = %ld\n", &errno, errno));
  81.     }
  82.     }
  83.  
  84.   return -1;
  85. }
  86.